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SYSTEM AND METHOD FOR NETWORK SECURITY 

Field of the Invention 

The invention relates to the field of communications, and more 
5 particularly to advanced network security. 

Background of the Invention 

The consistent demand for computer and other network services has 
increased the need for better network security tools. A variety of techniques 

10 have been deployed to shield networks from hacking and other intrusions. 
Those protective techniques may be categorized as either risk avoidance 
systems or risk management systems. 

Risk avoidance techniques involve introducing a barrier to prevent 
inappropriate entry into a network. Such systems place reliance on keeping 

15 intruders out of the network entirely, rather than monitoring inappropriate 
network traffic after logging in. Risk avoidance systems include dedicated 
network firewalls and mandatory encryption over the network. Commercial 
examples include Gauntlet™, Firewall- 1™, Guardian™, BorderWare™ and 
others. 

20 Risk management approaches, in contrast, adopt the philosophy that a 

network can not keep everyone out, and so rely upon detection of intrusive 
activity after logging in. Unfortunately, intrusion detector systems often lend a 
false sense of security to systems administrators, while not really solving the 
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underlying security problem. Intrusion detector systems produce a high rate of 
false positive identification, by inaccurately reporting legitimate network 
activity as suspicious. Intrusion detector systems also often overwhelm a 
systems administrator with too much detail about network behavior, and 
5 moreover are configured to trigger a report only after discovery of a network 
attack. Of course, at this point in time it is too late to prevent the attack or often 
to remedy much of the possible damage. Commercial examples include ISS 
RealSecure™, NetRanger™, TACAS+, NFR and others. 

After-the-fact auditing systems provide another type of tool used under 
10 the risk management approach. Auditing systems are implemented as a host- 
based technique, in which a central server running the operating system logs the 
activity of client computers in a central storage area. However, the host 
computer running the audit system itself may be susceptible to being attacked 
internally or externally, creating a point of vulnerability in the overall 
15 surveillance. 

Some other auditing products, such as Session Wall-3™ from AbirNet, 
employ so-called sniffer technology to monitor network traffic. Data streams 
collected by such products look for specific types of network traffic, for 
example, detecting electronic mail uploads by monitoring port 25 for simple 
20 mail transfer protocol (SMTP) events. However, most networks carry a large 
amount of traffic and sniffer type tools do not help sift through the volume. 
Other drawbacks exist. 



PATENT APPLICATION 
Attorney Docket No. 55789.000003 

3 

More robust and comprehensive network security technology is 
desirable. 

Summary of the Invention 

The invention overcoming these and other problems in the art relates to 
a system and method for network security capable of comprehensive network 
surveillance. The invention incorporates both network monitoring ports and 
analysis tools which enable a systems administrator to unobtrusively, but 
thoroughly, profile the entire range of network activity. The invention is 
incorporated into computer and other installations at the network level, and 
generally includes a dedicated observation port which passes the entire range of 
network traffic into a system interpreter. 

The collected information, typically in the form of packets, is subjected 
to a series of reductions to network sessions, metadata and eventually to 
statistical or other summary presentations. The invention thus subjects network 
traffic to a hierarchical series of real-time or forensic treatments, in which no 
type of data or network activity is excluded. Because the invention is only 
reading data at the network level and does not rely upon a central server running 
other tasks, the security protection offered is difficult or impossible to 
circumvent or corrupt. Because the entire data stream of the network is 
captured and profiled and profiling is not dependent on one subset of port 
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assignments or boundary conditions, forensic inspection of past network activity 
is enhanced. 

Brief Description of the Drawings 
The invention will be described with respect to the accompanying 
5 drawings, in which like elements are represented by like numbers. 

Fig. 1 illustrates a network architecture for security according to the 
invention. 

Fig. 2 is a flow chart illustrating surveillance and auditing processing 
according to the invention. 
10 Fig. 3 illustrates a presentation interface for viewing and analyzing data 

collected by the invention. 

Fig. 4 illustrates the operation of an interpreter module according to the 
invention. 

Fig. 5 illustrates the operation of an assembler module and parser 
1 5 module according to the invention. 

Detailed Description of Preferred Embodiments 
The invention will be described with respect to a network architecture 
illustrated in Fig. 1, in which a network observation port 104 monitors a 
20 network data stream 144 traveling over a network 142. Network 142 may be or 
include as a segment any one or more of, for instance, the Internet, an intranet, a 
PAN (Personal Area Network), a LAN (Local Area Network), a WAN (Wide 
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Area Network) or a MAN (Metropolitan Area Network), a frame relay 
connection, an Advanced Intelligent Network (AIN) connection, a synchronous 
optical network (SONET) connection, a digital Tl, T3 or El line, Digital Data 
Service (DDS) connection, DSL (Digital Subscriber Line) connection, an 
5 Ethernet connection, an ISDN (Integrated Services Digital Network) line, a dial- 
up port such as a V.90, V.34 or V.34bis analog modem connection, a cable 
modem, an ATM (Asynchronous Transfer Mode) connection, or FDDI (Fiber 
Distributed Data Networks) or CDDI (Copper Distributed Data Interface) 
connections. 

10 Network 142 may furthermore be or include as a segment any one or 

more of a WAP (Wireless Application Protocol) link, a GPRS (General Packet 
Radio Service) link, a GSM (Global System for Mobile Communication) link, a 
CDMA (Code Division Multiple Access) or TDMA (Time Division Multiple 
Access) link such as a cellular phone channel, a GPS (Global Positioning 

15 System) link, a Bluetooth radio link, or an IEEE 802.1 1-based radio frequency 
link. Network 142 may yet further be or include as a segment any one or more 
of an RS-232 serial connection, IEEE- 1394 (Firewire) connections, an IrDA 
(infrared) port, a SCSI (Small Computer Serial Interface) connection, a USB 
(Universal Serial Bus) connection or other wired or wireless, digital or analog 

20 interfaces or connections. 

The network data stream 144 traversing the network 142 in the 
illustrative embodiment is a sequence of digital bits, which network observation 
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port 104 senses and collects. Network observation port 104 may be 
implemented in a computer workstation configured with a network interface 
card (NIC), with that device configured to promiscuous mode so that all data is 
communicated transparently through the network observation port 104. 
5 However, in the implementation of the invention, network observation 

port 104 is preferably embedded in the network without a separate network 
address, so that its presence on the network is not discernible to network users. 
Network observation port 104 is likewise preferably installed on a network 
node, such as a computer workstation or server, which is not responsible for and 
10 does not run the network operating system for the network 142. The computer 
workstation or server which hosts network observation port 104 may be, for 
instance, a workstation running the Microsoft Windows™ NT™, Unix, Linux, 
Xenix, Solaris™, OS/2™, BeOS™, Mach, OpenStep™ or other operating 
system or platform software. 
15 As the realtime network data stream 144 is sensed and collected, the 

network observation port 104 transmits a copy of the network data stream 144 
in the form of collected data stream 106 to interpreter module 108 over 
connection 146. Interpreter module 108 accepts the collected data stream 106 
and interprets the collected data stream 106 into logical groupings, as illustrated 
20 in Fig. 4. This process is sometimes called fragment reassembly. 

For instance, interpreter module 108 may interpret collected data stream 
106 into Ethernet packets in an Ethernet implementation, and strip information 
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off from those packets that will be extraneous to the further treatment of the 
collected data stream 106. 

In an Ethernet environment, address information in the header reflects a 
media access control (MAC) hardware address, which is an absolute value and 
not readily mapped to a user or host, which have a logical rather than physical 
address. The interpreter module 108 thus removes the portions of the collected 
data stream 106 which contain the hardware-bound Ethernet header and 
processes the IP packet content. Interpreter module 108 transmits the resulting 
data packets 1 10 over communications link 148 to an assembler module 112. 

The assembler module 112 accepts the incoming data packets 110 to 
perform a next level of data analysis. More particularly, the assembler module 
112 consolidates the arriving data packets 110 into complete session files 118 
representing discrete network events, such as data access and downloads by 
individual users. Individual session files 118 may be, for instance, transfer 
control protocol (TCP) sessions reflecting Internet activity. 

As another variety of detectable transmissions, streaming video 
connections may be transmitted using the user datagram protocol (UDP) 
standard which is a connectionless protocol, since individual packets do not 
relate to or depend on preceding or following packets. Given that a UDP packet 
arrives in data packets 110 and is unique, that packet is added to a reassembly 
queue 180 (illustrated in Fig. 1) by assembler module 1 12. 



PATENT APPLICATION 
Attorney Docket No. 55789.000003 

8 

If a subsequent UDP packet arrives with the same IP addresses and the 
same application ports, before the original packet is marked complete, it will be 
assumed to be part of the original packet session and reassembled. The criteria 
for a session to be marked complete in the case of UDP is that the user defined 
5 timeout period (preferably with a default such as 30 seconds) is reached, and 
that the assembler module 1 12 activates an iterator module 178 on the session. 
The iterator module 178 only acts when the assembler module 1 12 enters an idle 
state, and flushes completed sessions. 

Assembler module 112, however, may deduce that a series of data 
10 packets 1 10 containing the same source and destination addresses and traversing 
the network 142 at the same time are part of a single UDP session, and output a 
UDP object into session file 1 18 accordingly. Other protocols may be deduced 
from the data packets presented to assembler module 112. The assembler 
module 112 of the invention, for instance, is not limited to recognizing, and 
15 does not presume that, all of data packets 110 are arriving under the TCP /TP 
protocol. 

Assembler module 1 12 may also contain external application port 1 14 
for accepting network packet information collected from separate external 
applications 1 16, such as conventional sniffer packages or others. 
20 After storing the sessions into session file 118, the assembler module 

1 12 transmits the sessions 140 to parser module 120 via connection 158. 
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The parser module 120 stores an overall log of the sessions 140 into 
session database 122. Parser module 120 contains application sensor module 
126 that is invoked for each session 140 to determine the type of application 
that generated the session. Application sensor 126 uses port assignments, lexical 
information and other data related to sessions 140 to determine what type of 
extractor 128 to invoke to process given session 140 Application sensor 126 
includes a library of classes of extractors 128 to call up to process sessions 140. 

Application sensor 126 characterizes the application type of sessionsl40 
by analyzing a variety of information contained in and characterizing the 
session 140. That information may include source and destination addresses, 
sequence numbers, source and destination ports, and other parameters as 
illustrated in Fig. 5. 

Sessions 140 of TCP and other protocols are characterized based in part 
upon a keyword lexicon analysis. In this regard, parser module 120 contains a 
lexicon module 174 which analyzes sessions 140 to flag the presence of 
keyword phrases consistent with different types of TCP sessions. Accumulated 
information concerning these flags, such as the presence of discreet keywords or 
totals for keyword occurrences, are used to identify enumerated network 
objects. 

For some types of network information, the occurrence of a single 
keyword may indicate the presence of an associated data object. For others, the 
total number of keyword occurrences, a weighted metric or other information 
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may be compared to a threshold or other criteria to establish that category of 
event. 

For instance, the presence of the phrase "/r/nfrom:" is illustratively 
flagged for candidacy as both an email and news article object. However, the 
5 keyword £ Vr/nNewsGroup:" correlates only to a news object. The logical trigger 
for news articles may be the presence of a flag for "/r/nnewsgroup:" being 
present and flagged. Similarly, the logical trigger for the presence of email may 
be positive flags for the terms "/r/nFrom:" in addition to the phrase "/r/nTo:". 

An example of a procedure call, invoked by the sensor module 126, to 
10 identify an SMTP event follows. The code in the following table (illustratively 
in C++, although it will be understood that other languages may be used) may 
be employed according to the invention to isolate those types of mail 
transmissions. 



15 Table 1 

A HELO { 

Flaglt (APP_STATE, APP_SMTP, SMTPHELO); 

} 

A data[$] { 

20 Flaglt (APP_STATE, APP_SMTP, SMTPDATA); 

} 

A data\r { 

Flaglt (APP_STATE, APP_SMTP, SMTPDATA); 

} 

25 A "mail from"[ ]*: { 

Flaglt (APP_STATE, APP_SMTP, SMTPMAILFROM); 

} 

A "rcptto"[]*: { 

Flaglt (APP_STATE, APP_SMTP, SMTPRCPTTO); 

30 } 
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A EHLO { 

Flaglt (APP_STATE, APP_SMTP, SMTPHELO); 

} 

5 #define MIN SMTPMATCH(X) ((X) & SMTPHELO && (X) & SMTPDATA 
&& (X) & SMTPRCPTTO) 

According to the foregoing procedure call, each occurrence of the word 
1 0 "HELO" preceded by a line feed (' A ') is flagged as a SMTPHELO. According 
to the Minimum Match Criteria (MTNSMTPMATCH), if a 'SMTPHELO', 
'SMTPDATA', and 'SMTPRCPTTO' is found, the match is made and an 
SMTP parser is called. 

1 5 Similarly, in terms of profiling and triggering a HTTP/HTML event, the 

following procedure call may be employed. 



Table 2 

"GET " { /*BEGINNING of HTTP STUFF */ 
20 Flaglt (APP_STATE, APP_HTTP, HTTPGET); 

} 

"Referer: " { 

Flaglt (APP_STATE, APP_HTTP, HTTP REF ERER) ; 

} 

25 "Accept: " { 

Flaglt (APP_STATE, APP_HTTP, HTTP ACCEPT); 

} 

"User-Agent: " { 

Flaglt (APP_STATE, APP_HTTP, HTTPUSERAGENT); 

30 } 

"HTTP/" [0-9] " ." [0-9] { 

Flaglt (APP_STATE, APP_HTTP, HTTP VERSION); 

} 

35 

/* HTML FLAGS */ 



12 
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"<HTML" { 

Flaglt (CONTENT_STATE , CNT_HTML, HTMLTAG); 

} 

5 *'<A HREF" { 

Flaglt (CONTENT_STATE, CNT_HTML, HTMLHREF); 

} 

"<H1" { 

Flaglt (CONTENT_STATE, CNT_HTML, HTMLH1); 

10 } 

"</a" { 

Flaglt (CONTENT_STATE, CNT_HTML, HTML ANCHOR) ; 

} 

15 "<HEAD>" { 

Flaglt (CONTENT_STATE, CNT_HTML, HTMLHEAD); 
} 

"<BODY" { 

20 Flaglt (CONTENT_STATE, CNTJHTML, HTMLBODY); 

} 

#define MINHTTPMATCH(X) ((X) & HTTP VERSION) 
#define MINHTMLMATCH(X) ((X) & HTMLTAG && (X) & HTMLHEAD 
25 && (X) & HTMLBODY) 



Other protocols may be triggered upon other corresponding lexical 
triggers, or other types of information when the network event is not textually- 
30 based. For example, the original network data stream 144 may be sampled 
during a streaming video, voice-over-network or other virtual connections 
which are not encapsulated in a textual or TCP format. 

Because network protocols may be nested, for example, a POP-3 session 
may contain one or more instances of RFC822 email sessions, application 
35 sensor 126 may be applied recursively to identify protocols within other 
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protocols to extract nested or underlying objects encapsulated in one or more 
different protocols. 

The protocols the invention may detect include, but are not limited to, 
TCP, IP, UDP, SMTP, HTTP, NNTP, FTP, TELNET, DNS, RTP, BGP, MAIL, 
5 NEWS, HTML, XML, PGP, S/MIME, POP, IMAP, V-CARD, ICMP, NetBUI, 
IPX and SPX objects, understood by persons skilled in the art. The universe of 
protocols that sensor module 128 can detect and identify is extensible, and can 
be added to or subtracted from to accommodate future protocols and for other 
network needs. 

1 0 Once application type of session 1 40 has been determined by application 

sensor 126, parser module 120 may, depending upon configuration information 
and type of session, store part or all of a complete session to content database 
182 after assignation of a unique storage address. 

The parser module 120 also contains extractor module 128, which 

15 processes the determined protocol for a given session 140 and generates the 
minimum subset of information needed to identify the nature of session 140 for 
recording on session database 122, removing unnecessary information before 
storage. Information may be reduced using text compression and other 
techniques. Because network protocols are designed to nest, extractor 128 is 

20 applied recursively to process protocols within other protocols, as identified by 
sensor 126. Depending on the category of session 140, the data reduction from 
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the original network sessions to the metadata image of the session (each stored 
on session database 122) may be on the order of 100 to 1 or greater. 

Depending on the size of network 142, the bandwidth of network data 
stream 144 and other factors, the storage requirements of session database 122 

5 may be substantial. However, the storage requirement of the invention is 
commensurate with the comprehensive nature of the surveillance performed and 
affords system administrators the opportunity to perform more fully featured 
post hoc traffic analysis. 

At the back end of the network apparatus of the invention, a presentation 

10 interface 138 (illustrated in more detail in Fig. 3) communicates via 
communication line 168 to a presentation server 136. The presentation server 
136 may be a workstation or other device, such as a personal computer running 

TM TM TM TM 

the Microsoft Windows 95,' 98, NT , Unix, Linux, Solaris , OS/2 , 
BeOS™, MacOS™ or other operating system. The presentation interface 138 
15 may be accessed by a systems administrator wishing to perform network 
investigation or maintenance, and may be connected to presentation server 136 
for example via a common gateway interface (CGI) bin or other Web service 
interfaces. 

The presentation server 136 is in turn connected via communications 
20 link 166 to a summary database 132, which is in turn connected via connection 
164 to session database 122. The session database 122 and summary database 
132 may in one regard be serviced by the same database engine, such as an 
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online analytic processing (OLAP) interface. Execution of scripts through an 
OLAP or other engine such as a relational database engine accessed by Standard 
Query Language (SQL) generates the summary database 132 from searches on 
the session database 122. 
5 Presentation interface 138 allows a systems administrator to invoke a 

graphical or other menu of different inquiries into the past behavior of network 
142. Those inquiries may include an investigation of Websites most frequently 
visited by users of the network, individual users exhibiting the highest rate of e- 
mail traffic including images of the e-mail messages themselves, nodal analyses 

10 of different network addresses and their most frequent communicants, and other 
information recorded in the resulting databases. 

The variety of forensic inquires that may be formulated through 
presentation interface 138 is in part a function of the complete nature of the 
surveillance performed by the invention, and the storage of the results of those 

15 interrogations in summary database 132 also allows further treatment by 
characterization module 134 communicating with summary database 132 over 
connection 172. 

The characterization module 134 may store high-level, digested data 
indicating the overall behavior of network 142, such as peak traffic times, 
20 distribution of utilized bandwidths across the network over time, general degree 
of user activity and other categories of characteristic data. 
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Presentation interface 138 may overlay the graphical or other depiction 
of the network behavior with system policy constraints or goals, such as limits 
on Web access or e-mail traffic, to visually show how different facets of the 
network are complying or behaving. Presentation interface 138 may, if desired, 
5 be connected to a printer or other output device (not shown) to produce hard 
copy of the different varieties of reports prepared according to the invention. 

Similarly, summary database 132 may include ports to other external 
applications to receive further collateral information concerning network 
behavior, such as employee lists, accounting records and other packages. 

10 The overall processing flow of the invention is illustrated in Figure 2. In 

step 202, processing begins. In step 204, bits from the network data stream 144 
are collected by network observation port 104 into collected data stream 106. In 
step 206, the collected data stream 106 is transmitted to interpreter module 108. 
In step 208, the interpreter module 108 resolves the collected data stream 106 

15 into data packets 110. In step 210, the assembler module 1 12 accepts additional 
packets from any external application ports, if any are present. 

In step 212, assembler module 112 assembles data packets 110 into 
individual sessions 140, storing new sessions in session file 118. In step 214, 
assembler module 112 transmits copies of the sessions 140 to parser module 

20 120. In step 216, the parser module 120 invokes the sensor module 126 to 
assign a session type to individual sessions 140. 
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In step 218, the extractor module 128 is invoked to extract the minimum 
essential session data to be reflected in summary database 132. In step 220, 
parsed session information is stored in session database 122. In step 222, the 
summary database 132 is generated by executing OLAP scripts or other search 
5 or query mechanisms against session database 122. In step 224, the 
presentation interface 138 is presented to a systems administrator or other user. 

In step 226, a user inquiry is accepted, such as an interrogation from a 
systems administrator. In step 228, the user inquiry is input to the presentation 
server 136. In step 230, the presentation server 136 analyzes the query 

10 parameters and communicates with the summary database 132. In step 232, the 
characterization module 134 is executed. In step 234, the resulting graphical or 
other data are presented to the user via the presentation interface 138. In step 
236, processing ends. 

The foregoing description of the system and method of the invention is 

15 illustrative, and variations in configurations and implementation will be 
apparent to persons skilled in the art. For instance, while the interpreter module 
108 has been illustrated as accepting input form a single network observation 
port 104, interpreter module 108 could accept samples of the network data 
stream 144 from multiple ports. 

20 Similarly, while presentation interface 138 has been illustrated as an 

interactive module accepting analytic requests from a user, predetermined sets 
of reports can be executed by presentation server 136, summary database 132 
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and associated components in batch fashion. While certain functions have been 
described as being stored on and executed by individual modules, servers and 
other network elements, it will be appreciated that different aspects of the 
control and analysis of the invention maybe executed by different computers or 
other devices, in distributed fashion. The scope of the invention is accordingly 
intended only to be limited by the following claims. 
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Claims 

What is claimed is: 

1 . A system for extracting information from network data, comprising: 
an input interface connected to at least one source of network data; and 

5 a network event sensor, communicating with the input interface, the 

network event sensor applying at least a lexical engine to the network data to 
identify at least one network event. 

2. The system of claim 1, wherein the at least one source of network data 
comprises an observation port connected to a network and continuously 

1 0 capturing network data from the network. 

3. The system of claim 2, wherein the observation port comprises a 
network interface card. 

4. The system of claim 3, wherein the network comprises at least one of an 
Ethernet network, a token ring network, and a TCP/TP network. 

15 5. The system of claim 3, wherein the network interface card is invisible to 
the network. 

6. The system of claim 1, wherein the at least one source of network data 
comprises stored network data. 

7. The system of claim 6, wherein the stored network data comprise at least 
20 one of captured network files, Website mirrors, archives of Usenet files, and 

archives of email files. 
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8. The system of claim 1, further comprising an interpreter module, the 
interpreter module scanning the network data to generate logical groupings of 
the network data. 

9. The system of claim 8, wherein the logical groupings comprise packets. 
5 10. The system of claim 8, wherein the interpreter module removes low- 
level encoding information from the network data to generate the logical 
groupings. 

11. The system of claim 10, wherein the low-level encoding information 
removed by the interpreter module comprises hardware addressing information. 
10 12. The system of claim 8, further comprising an assembler module, 
communicating with the interpreter module, the assembler module scanning the 
logical groupings to generate at least one session object. 

13. The system of claim 12, wherein the at least one session object 
comprises at least one session file. 
15 14. The system of claim 12, wherein the assembler module scans the logical 
groupings by examining at least one of source address, destination address, 
sequence numbers, source port, and destination port to generate the at least one 
session object. 

15. The system of claim 12, wherein the network event sensor applies the 
20 lexical engine to the at least one session object to identify the at least one 
network event as at least one of a predetermined set of event types. 
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16. The system of claim 15, wherein the lexical engine detects the presence 
of at least one predefined keyword to identify the at least one of a predetermined 
set of event types. 

17. The system of claim 16, wherein the predetermined set of event types 
5 comprises at least one of TCP, TP, TJDP, SMTP, HTTP, NNTP, FTP, TELNET, 

DNS, RIP, BGP, MAIL, NEWS, HTML, XML, PGP, S/MTME, POP, IMAP, 
V-CARD, ICMP, NetBUI, IPX and SPX. 

18. The system of claim 16, wherein the lexical engine accumulates a total 
number of occurrences for the at least one predefined keyword to identify the 

10 event type. 

1 9. The system of claim 1 8, wherein the lexical engine applies a threshold to 
the number of occurrences to identify the event type. 

20. The system of claim 12, wherein the network event sensor applies the 
lexical engine recursively to identify more than one event type contained in the 

15 at least one session object. 

21. The system of claim 15, further comprising an extractor module, the 
extractor module extracting the at least one network event from the at least one 
session object according to the at least one of a predetermined set of event 
types. 

20 22. The system of claim 21, wherein the extractor module comprises a 
library of extractor types, each of the extractor types corresponding to at least 
one of the at least one of a predetermined set of event types. 
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23. The system of claim 22, wherein the extractor module stores a minimum 
subset of the network data to reconstruct the at least one network event. 

24. The system of claim 23, wherein the minimum subset of the network 
data is stored in a database. 

5 25. The system of claim 24, further comprising a presentation module, 
communicating with the database, the presentation module querying the 
database for information related to the at least one network event. 

26. The system of claim 1, wherein the network event sensor also applies a 
port detection engine to the network data to identify the at least one network 

10 event. 

27. The system of claim 1, wherein the at least one source of network data 
comprises a plurality of sources of network data. 

28. A method for extracting information from network data, comprising the 
steps of: 

15 a) receiving network data from at least one source of network data; and 

b) applying at least a lexical engine to the network data to identify at 
least one network event. 

29. The method of claim 28, wherein the at least one source of network data 
comprises an observation port connected to a network and continuously 

20 capturing network data from the network. 

30. The method of claim 29, wherein the observation port comprises a 
network interface card. 
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31. The method of claim 30, wherein the network comprises at least one of 
an Ethernet network, a token ring network, and a TCP/IP network. 

32. The method of claim 30, wherein the network interface card is invisible 
to the network. 

5 33. The method of claim 28, wherein the at least one source of network data 
comprises stored network data. 

34. The method of claim 33, wherein the stored network data comprise at 
least one of captured network files, Website mirrors, archives of Usenet files, 
and archives of email files. 
10 35. The method of claim 28, further comprising a step of c) scanning the 
network data to generate logical groupings of the network data. 

36. The method of claim 35, wherein the logical groupings comprise 
packets. 

37. The method of claim 35, further comprising a step of d) removing low- 
15 level encoding information from the network data to generate the logical 

groupings. 

38. The method of claim 37, wherein the low-level encoding information 
comprises hardware addressing information. 

39. The method of claim 35, further comprising a step of e) scanning the 
20 logical groupings to generate at least one session object. 

40. The method of claim 39, wherein -the at least one session object 
comprises at least one session file. 
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41. The method of claim 39, wherein the step (e) of scanning the logical 
groupings comprises a step of f) examining at least one of source address, 
destination address, sequence numbers, source port, and destination port to 
generate the at least one session object. 

5 42. The method of claim 39, further comprising a step of g) identifying the 
at least one network event as at least one of a predetermined set of event types. 
43. The method of claim 42, wherein the step (g) of identifying comprises a 
step of (h) detecting the presence of at least one predefined keyword to identify 
the at least one of a predetermined set of event types. 

10 44. The method of claim 43, wherein the predetermined set of event types 
comprises at least one of TCP, TP, UDP, SMTP, HTTP, NNTP, FTP, TELNET, 
DNS, RIP, BGP, MAIL, NEWS, HTML, XML, PGP, S/MIME, POP, IMAP, 
V-CARD, ICMP, NetBUI, IPX and SPX. 

45. The method of claim 43, wherein the step (h) of detecting comprises a 
15 step of (i) accumulating a total number of occurrences for the at least one 

predefined keyword to identify the event type. 

46. The method of claim 45, wherein the step (h) of detecting comprises a 
step 0) of applying a threshold to the number of occurrences to identify the 
event type. 

20 47. The method of claim 39, wherein the step of b) applying at least the 
lexical engine comprises a step of k) applying the lexical engine recursively to 
identify more than one event type contained in the at least one session object. 
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48. The method of claim 42, further comprising a step of 1) extracting the at 
least one network event from the at least one session object according to the at 
least one of a predetermined set of event types. 

49. The method of claim 48, wherein the step (1) of extracting comprises a 
5 step of m) selecting at least one extractor module from a library of extractor 

types, each of the extractor types corresponding to at least one of the at least one 
of a predetermined set of event types. 

50. The method of claim 49, further comprising a step of n) storing a 
minimum subset of the network data to reconstruct the at least one network 

10 event. 

5 1 . The method of claim 50, wherein the step (n) of storing comprises a step 
o) of storing the miriimum subset of the network data in a database. 

52. The method of claim 51, further comprising a step of p) querying the 
database for information related to the at least one network event. 

15 53. The method of claim 28, further comprising a step q) of applying a port 
detection engine to the network data to identify the at least one network event. 
54. The method of claim 28, wherein the at least one source of network data 
comprises a plurality of sources of network data. 



20 
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Abstract 

A system for network security transparently occupies an observation 
port on the data stream, passing the entire range of network information to a 
dedicated interpreter. The interpreter resolves the data stream into individual 
5 data packets, which are then assembled into reconstructed network sessions 
according to parameters such as protocol type, source and destination addresses, 
source and destination ports, sequence numbers and other variables. The 
different types of sessions may include the traffic of many different types of 
users, such as e-mail, streaming video, voice-over-Internet and others. The 

1 0 system detects and stores the sessions into a database. A parser module may 
extract only the minimum information needed to reconstruct individual sessions. 
A backend interface permits a systems administrator to interrogate the forensic 
record of the network for maintenance, security and other purposes. The 
invention is not constrained to detect limited types of data, but rather captures 

1 5 and records a comprehensive record of network behavior. 
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